import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

// eslint是什么?是一套语法规范
// 1.不要有多余的空白行
// 2.声明变量或常量,要使用它
// 3.数据前要有空白
// 4.字符串要使用单引号
// ...
// const a = 100

// 导入全局的global.less样式
import '@/assets/global.less'

// 下载注册element-ui
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'

// 下载配置axios
import axios from 'axios'

// 导入富文本编器包
import VueQuillEditor from 'vue-quill-editor'
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'

// 导入dayjs包
import dayjs from 'dayjs'

Vue.use(VueQuillEditor)

Vue.use(ElementUI)
axios.defaults.baseURL = 'http://www.liulongbin.top:3008'

// 设置axios请求拦截器
axios.interceptors.request.use((config) => {
  // Do something
  // 设置token请求头
  config.headers.Authorization = store.state.token

  return config
}, (err) => {
  return Promise.reject(err)
})

// 设置axios响应拦截器
axios.interceptors.response.use((response) => {
  return response
}, (error) => {
  if (error.response.status === 401) {
    // 1.清空token
    store.commit('updateToken', '')
    // 2.跳转登录页
    router.push('/login')
  }
  return Promise.reject(error)
})

Vue.prototype.$http = axios

// 配置全局的处理时间的过滤器
Vue.filter('dateFormat', (dataStr) => {
  return dayjs(dataStr).format('YYYY-MM-DD HH:mm:ss')
})

Vue.config.productionTip = false

new Vue({
  router,
  store,
  render: (h) => h(App)
}).$mount('#app')
